package problem.year2021.february;

import java.util.*;

/**
 * 外国友人仿照中国字谜设计了一个英文版猜字谜小游戏，请你来猜猜看吧。
 * 字谜的迷面 puzzle 按字符串形式给出，如果一个单词 word 符合下面两个条件，那么它就可以算作谜底：
 * 单词 word 中包含谜面 puzzle 的第一个字母。
 * 单词 word 中的每一个字母都可以在谜面 puzzle 中找到。
 * 例如，如果字谜的谜面是 "abcdefg"，那么可以作为谜底的单词有 "faced", "cabbage", 和 "baggage"；而 "beefed"（不含字母 "a"）以及 "based"（其中的 "s" 没有出现在谜面中）。
 * 返回一个答案数组 answer，数组中的每个元素 answer[i] 是在给出的单词列表 words 中可以作为字谜迷面 puzzles[i] 所对应的谜底的单词数目。
 * 示例：
 * 输入：
 * words = ["aaaa","asas","able","ability","actt","actor","access"],
 * puzzles = ["aboveyz","abrodyz","abslute","absoryz","actresz","gaswxyz"]
 * 输出：[1,1,3,2,4,0]
 * 解释：
 * 1 个单词可以作为 "aboveyz" 的谜底 : "aaaa"
 * 1 个单词可以作为 "abrodyz" 的谜底 : "aaaa"
 * 3 个单词可以作为 "abslute" 的谜底 : "aaaa", "asas", "able"
 * 2 个单词可以作为 "absoryz" 的谜底 : "aaaa", "asas"
 * 4 个单词可以作为 "actresz" 的谜底 : "aaaa", "asas", "actt", "access"
 * 没有单词可以作为 "gaswxyz" 的谜底，因为列表中的单词都不含字母 'g'。
 * 提示：
 * <p>
 * 1 <= words.length <= 10^5
 * 4 <= words[i].length <= 50
 * 1 <= puzzles.length <= 10^4
 * puzzles[i].length == 7
 * words[i][j], puzzles[i][j] 都是小写英文字母。
 * 每个 puzzles[i] 所包含的字符都不重复。
 */
public class February26 {
    public List<Integer> findNumOfValidWords(String[] words, String[] puzzles) {
        List<Integer> answer = new ArrayList<>();
        for (String str : puzzles) {
            answer.add(fun1(words, str));
        }
        return answer;
    }

    // 判断多少个单词是str的谜底
    private int fun1(String[] words, String str) {
        int answer = 0;
        for (String s : words) {
            if (fun2(s, str)) {
                answer++;
            }
        }
        return answer;
    }

    // 判断是不是谜底
    private boolean fun2(String word, String str) {
        char[] words = word.toCharArray();
        char[] chars = str.toCharArray();
        Set<Character> set = new HashSet<>();
        for (char c : words) {
            set.add(c);
        }
        if (!set.contains(chars[0])) return false;
        Set<Character> set2 = new HashSet<>();
        for (char c : chars) {
            set2.add(c);
        }
        if (set2.containsAll(set)) return true;
        return false;
    }

    public static void main(String[] args) {
        // words = ["aaaa","asas","able","ability","actt","actor","access"],
        // puzzles = ["aboveyz","abrodyz","abslute","absoryz","actresz","gaswxyz"]
        // 输出：[1,1,3,2,4,0]
        String[] strings = {"aaaa", "asas", "able", "ability", "actt", "actor", "access"};
        String[] strings1 = {"aboveyz", "abrodyz", "abslute", "absoryz", "actresz", "gaswxyz"};
        List<Integer> words = new February26().findNumOfValidWords(strings, strings1);
        System.out.println(words.toString());
    }
}
